## **Answers Database**

# Virtex-4 RocketIO Wizard v 1.4 - GT11\_INIT State Machine startup failure

Answer Record: 25469

Family: Hardware

Product Line: MGT

Part: HW-Rocket\_IO

Version:

Last Modified: 07/25/07 05:53:42

Status: Active

### **Problem Description:**

Keywords: GT11, MGT, COREGen, CORE Generator, VHDL, Verilog, FSM

The GT11\_INIT State Machine that is included in the Virtex-4 RocketIO Wizard example design contains an asynchronous input that can cause the state machine to go into an unknown state. This Answer Record describes the fix for this issue.

#### Solution 1:

The Virtex-4 RocketIO Wizard contains two modules that control MGT resets. The GT11\_INIT\_TX and GT11\_INIT\_RX modules are one-hot encoded state machines that are synchronous to DCLK. Both of these modules look at the MGT PLL lock detect ports and the DCM Lock detect port to move between states.

The MGT PLL lock detect signal (called LOCK) gets registered by DCLK before being sent into the state machine. The problem is that the DCM Lock signal (called USRCLK\_STABLE) does not get registered by DCLK before being sent to the state machine.

To fix this issue, register USRCLK\_STABLE before it gets ANDed with the lock\_r signal.

### GT11\_INIT\_TX Example

```
-- Synchronize LOCK
process(CLK)
if(CLK'event and CLK = '1') then
if (reset_r(0) = '1') then
lock_r <= '0';
usrclk_stable_r <= '0';
else
lock r <= LOCK;
usrclk_stable_r <= USRCLK_STABLE; -- Synchronize DCM Lock
end if:
end process;
init fsm wait lock check <= lock r and usrclk stable r;
GT11_INIT_RX Example
______
-- Synchronize LOCK
process(CLK)
begin
if(CLK'event and CLK = '1') then
if (reset_r(0) = '1') then
lock_r <= '0';
usrclk_stable_r <= '0';
else
lock_r <= LOCK;
```

1 sur 2 2007-10-10 09:14

```
usrclk_stable_r <= USRCLK_STABLE; -- Synchronize DCM Lock end if; end if; end process; ... init_fsm_wait_lock_check <= lock_r and usrclk_stable_r and lockupdate_ready_i; Virtex-4 RocketIO Wizard v1.5 fixes this issue.
```

2 sur 2